JavaScript must be enabled to play.
Browser lacks capabilities required to play.
Upgrade or switch to another browser.
Loading…
<<set $map to [[0,0,0,0,0,0,0,0,0,0,0], [0,1,1,1,0,3,1,1,1,1,0], [0,0,0,1,0,0,0,0,0,1,0], [0,1,0,1,1,1,1,1,0,1,0], [0,1,0,0,0,0,0,1,0,1,0], [0,1,1,1,1,1,1,1,0,1,0], [0,0,0,0,0,0,0,1,0,1,0], [0,1,0,1,1,1,1,1,1,1,0], [0,1,0,1,0,0,0,1,0,0,0], [0,1,1,1,0,1,1,1,1,1,0], [0,0,0,0,0,0,0,0,0,0,0]]>>\ <<set $px to 9>><<set $py to 9>>\ <div id="map"></div>\ <<done>><<update>><</done>>\ <<link "North">><<if $px gt 1 and $map[$px-1][$py] is 1>><<set $map[$px][$py] to 1>><<set $px-->><<update>><</if>><</link>> <<link "South">><<if $px lt 10 and $map[$px+1][$py] is 1>><<set $map[$px][$py] to 1>><<set $px++>><<update>><</if>><</link>> <<link "East">><<if $py lt 10 and $map[$px][$py+1] is 1>><<set $map[$px][$py] to 1>><<set $py++>><<update>><</if>><</link>> <<link "West">><<if $py gt 1 and $map[$px][$py-1] is 1>><<set $map[$px][$py] to 1>><<set $py-->><<update>><</if>><</link>> [[Code]]




<<widget "update">>\ <<replace #map>>\ <<for $x to 0; $x lt 10; $x++>>\ <<for $y to 0; $y lt 10; $y++>>\ <<set $map[$px][$py] to 2>>\ <<switch $map[$x][$y]>>\ <<case 0>><img data-passage="block.png">\ <<case 1>><img data-passage="empty.png">\ <<case 2>><img data-passage="alien.gif">\ <<case 3>><img data-passage="snack store.png">\ <</switch>>\ <</for>>\ <br>\ <</for>>\ <</replace>>\ <</widget>>
<<run UIBar.destroy()>>
Initial passage: {{{ <<set $map to [[0,0,0,0,0,0,0,0,0,0,0], [0,1,1,1,0,3,1,1,1,1,0], [0,0,0,1,0,0,0,0,0,1,0], [0,1,0,1,1,1,1,1,0,1,0], [0,1,0,0,0,0,0,1,0,1,0], [0,1,1,1,1,1,1,1,0,1,0], [0,0,0,0,0,0,0,1,0,1,0], [0,1,0,1,1,1,1,1,1,1,0], [0,1,0,1,0,0,0,1,0,0,0], [0,1,1,1,0,1,1,1,1,1,0], [0,0,0,0,0,0,0,0,0,0,0]]>>\ <<set $px to 9>><<set $py to 9>>\ <div id="map"></div>\ <<done>><<update>><</done>>\ <<link "Norte">><<if $px gt 1 and $map[$px-1][$py] is 1>><<set $map[$px][$py] to 1>><<set $px-->><<update>><</if>><</link>> <<link "Sul">><<if $px lt 10 and $map[$px+1][$py] is 1>><<set $map[$px][$py] to 1>><<set $px++>><<update>><</if>><</link>> <<link "Oeste">><<if $py gt 1 and $map[$px][$py-1] is 1>><<set $map[$px][$py] to 1>><<set $py-->><<update>><</if>><</link>> <<link "Leste">><<if $py lt 10 and $map[$px][$py+1] is 1>><<set $map[$px][$py] to 1>><<set $py++>><<update>><</if>><</link>> }}} The "update" widget (must be in a "widget" tagged passage) {{{ <<widget "update">>\ <<replace #map>>\ <<for $x to 0; $x lt 10; $x++>>\ <<for $y to 0; $y lt 10; $y++>>\ <<set $map[$px][$py] to 2>>\ <<switch $map[$x][$y]>>\ <<case 0>><img data-passage="block.png">\ <<case 1>><img data-passage="empty.png">\ <<case 2>><img data-passage="alien.gif">\ <<case 3>><img data-passage="snack store.png">\ <</switch>>\ <</for>>\ <br>\ <</for>>\ <</replace>>\ <</widget>> }}} Stylesheet: {{{ #map { line-height: 0; border: 1px dotted; width: 50vh; } img { width: auto; height: 5vh; } #story { margin: auto; } body { color: #111; background-color: #fff; } }}} Based on [[Moving through a dungeon|https://twinery.org/cookbook/dungeonmoving/sugarcube/sugarcube_dungeonmoving.html]] from the Twine Cookbook. This example uses [[media passages|https://motoslave.net/sugacube/2/docs/#guide-media-passages]] created with [[Twine Enhancer|https://github.com/hogart/twine-enhancer]]. [[Voltar|Mapa]]